package condominios.dao;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Collection;

import condominios.excepcion.DAOExcepcion;
import condominios.modelo.MensajeInterno;
import condominios.util.ConexionBD;
import condominios.util.utilitario;

public class MensajeInternoDAO extends BaseDAO {
	
	public Collection<MensajeInterno> listar() throws DAOExcepcion {

		System.out.println("MensajeInternoDAO: listar()");

		String query = "SELECT idMensajeInterno, titulo, contenido, fechaPublicacion, estado FROM mensajeinterno where estadoRegistro=1 and estado=1"
				+ " order by fechaPublicacion desc";
		
		Collection<MensajeInterno> lista = new ArrayList<MensajeInterno>();
		Connection con = null;
		PreparedStatement stmt = null;
		ResultSet rs = null;
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			
			rs = stmt.executeQuery();
			
			while (rs.next()) {

				MensajeInterno item = new MensajeInterno();
				item.setIdMensajeInterno(rs.getInt("idMensajeInterno"));
				item.setTitulo(rs.getString("titulo"));
				item.setContenido(rs.getString("contenido"));
				item.setFechaPublicacion(rs.getTimestamp("fechaPublicacion"));

				lista.add(item);
			}
			
		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarResultSet(rs);
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}

		return lista;
	}

	public void insertar(MensajeInterno vo) throws DAOExcepcion {
		System.out.println("MensajeInternoDAO: insertar(MensajeInterno vo)");
		String query = "INSERT INTO mensajeinterno (titulo, contenido, fechaPublicacion, estado, fechaCreo, idPersonaCreo, estadoRegistro) VALUES(?, ?, ?, ?, ?, ?, ?)";
		Connection con = null;
		PreparedStatement stmt = null;
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			
			stmt.setString(1, vo.getTitulo());
			stmt.setString(2, vo.getContenido());
			stmt.setString(3, utilitario.fnFechaMySql(vo.getFechaPublicacion()));
			
			stmt.setBoolean(4, vo.isEstado() );
			stmt.setString(5, utilitario.fnFechaHoraMySql(vo.getFechaCreo()));
			stmt.setInt(6, vo.getIdPersonaCreo());
			stmt.setBoolean(7, vo.isEstadoRegistro());
			
			int i = stmt.executeUpdate();
			if (i != 1) {
				throw new SQLException("No se pudo insertar");
			}
		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
	}

}
